/*
 * This program is free software: you can redistribute it and/or modify it under
 * the terms of the GNU General Public License as published by the Free Software
 * Foundation, either version 3 of the License, or (at your option) any later
 * version.
 * 
 * This program is distributed in the hope that it will be useful, but WITHOUT
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
 * FOR A PARTICULAR PURPOSE. See the GNU General Public License for more
 * details.
 * 
 * You should have received a copy of the GNU General Public License along with
 * this program. If not, see <http://www.gnu.org/licenses/>.
 */
package net.sf.l2j.gameserver.model.entity;

import java.sql.Connection;
import java.sql.PreparedStatement;
import java.sql.ResultSet;
import java.util.Calendar;
import java.util.logging.Logger;

import net.sf.l2j.L2DatabaseFactory;
import net.sf.l2j.gameserver.idfactory.IdFactory;
import net.sf.l2j.gameserver.model.L2World;
import net.sf.l2j.gameserver.model.actor.instance.L2PcInstance;

/**
 * @author evill33t
 *
 */
public class Couple
{
private static final Logger _log = Logger.getLogger(Couple.class.getName());

// =========================================================
// Data Field
private int _Id = 0;
private int _player1Id = 0;
private int _player2Id = 0;
private boolean _maried = false;
private Calendar _affiancedDate;
private Calendar _weddingDate;

// =========================================================
// Constructor
public Couple(int coupleId)
{
	_Id = coupleId;
	
	Connection con = null;
	try
	{
		PreparedStatement statement;
		ResultSet rs;
		
		con = L2DatabaseFactory.getInstance().getConnection();
		
		statement = con.prepareStatement("Select * from mods_wedding where id = ?");
		statement.setInt(1, _Id);
		rs = statement.executeQuery();
		
		while (rs.next())
		{
			_player1Id = rs.getInt("player1Id");
			_player2Id = rs.getInt("player2Id");
			_maried = rs.getBoolean("married");
			
			_affiancedDate = Calendar.getInstance();
			_affiancedDate.setTimeInMillis(rs.getLong("affianceDate"));
			
			_weddingDate = Calendar.getInstance();
			_weddingDate.setTimeInMillis(rs.getLong("weddingDate"));
		}
		statement.close();
	}
	catch (Exception e)
	{
		_log.severe("Exception: Couple.load(): " + e);
	}
	finally
	{
		try
		{
			con.close();
		}
		catch (Exception e)
		{
		}
	}
}

public Couple(L2PcInstance player1, L2PcInstance player2)
{
	int _tempPlayer1Id = player1.getObjectId();
	int _tempPlayer2Id = player2.getObjectId();
	
	_player1Id = _tempPlayer1Id;
	_player2Id = _tempPlayer2Id;
	
	_affiancedDate = Calendar.getInstance();
	_affiancedDate.setTimeInMillis(Calendar.getInstance().getTimeInMillis());
	
	_weddingDate = Calendar.getInstance();
	_weddingDate.setTimeInMillis(Calendar.getInstance().getTimeInMillis());
	
	Connection con = null;
	try
	{
		con = L2DatabaseFactory.getInstance().getConnection();
		PreparedStatement statement;
		_Id = IdFactory.getInstance().getNextId();
		statement = con.prepareStatement("INSERT INTO mods_wedding (id, player1Id, player2Id, married, affianceDate, weddingDate) VALUES (?, ?, ?, ?, ?, ?)");
		statement.setInt(1, _Id);
		statement.setInt(2, _player1Id);
		statement.setInt(3, _player2Id);
		statement.setBoolean(4, false);
		statement.setLong(5, _affiancedDate.getTimeInMillis());
		statement.setLong(6, _weddingDate.getTimeInMillis());
		statement.execute();
		statement.close();
	}
	catch (Exception e)
	{
		_log.severe(e.toString());
	}
	finally
	{
		try
		{
			con.close();
		}
		catch (Exception e)
		{
		}
	}
}

public void marry()
{
	final L2PcInstance player1 = L2World.getInstance().getPlayer(_player1Id);
	final L2PcInstance player2 = L2World.getInstance().getPlayer(_player2Id);
	
	if (player1 == null || player2 == null)
	{
		_log.severe("cannot find player1 or 2 in marry()!");
		return;
	}
	
	Connection con = null;
	try
	{
		con = L2DatabaseFactory.getInstance().getConnection();
		PreparedStatement statement;
		
		statement = con.prepareStatement("UPDATE mods_wedding set married = ?, weddingDate = ? where id = ?");
		statement.setBoolean(1, true);
		_weddingDate = Calendar.getInstance();
		statement.setLong(2, _weddingDate.getTimeInMillis());
		statement.setInt(3, _Id);
		statement.execute();
		statement.close();
		_maried = true;
		
		statement = con.prepareStatement("UPDATE accounts set married = 1 where login = ?");
		statement.setString(1, player1.getAccountName());
		statement.execute();
		statement.close();
		
		statement = con.prepareStatement("UPDATE accounts set married = 1 where login = ?");
		statement.setString(1, player2.getAccountName());
		statement.execute();
		statement.close();
	}
	catch (Exception e)
	{
		_log.severe(e.toString());
	}
	finally
	{
		try
		{
			con.close();
		}
		catch (Exception e)
		{
		}
	}
	
	player1.getClient().setIsThisAccountMarried(true);
	player2.getClient().setIsThisAccountMarried(true);
}

public void divorce()
{
	Connection con = null;
	try
	{
		con = L2DatabaseFactory.getInstance().getConnection();
		PreparedStatement statement;
		
		statement = con.prepareStatement("DELETE FROM mods_wedding WHERE id=?");
		statement.setInt(1, _Id);
		statement.execute();
		statement.close();
	}
	catch (Exception e)
	{
		_log.severe("Exception: Couple.divorce(): " + e);
	}
	finally
	{
		try
		{
			con.close();
		}
		catch (Exception e)
		{
		}
	}
}

public final int getId()
{
	return _Id;
}

public final int getPlayer1Id()
{
	return _player1Id;
}

public final int getPlayer2Id()
{
	return _player2Id;
}

public final boolean getMaried()
{
	return _maried;
}

public final Calendar getAffiancedDate()
{
	return _affiancedDate;
}

public final Calendar getWeddingDate()
{
	return _weddingDate;
}
}
